(guint)archive_header_size, input_length);
goto out;
}
+ if (archive_header_size == 0)
+ {
+ g_set_error (error, G_IO_ERROR, G_IO_ERROR_FAILED,
+ "File header size is zero");
+ goto out;
+ }
/* Skip over padding */
if (!g_input_stream_read_all (input,
ot_clear_gvariant (&metadata);
if (!ostree_repo_load_variant (data->repo, objtype,
checksum, &metadata, error))
- goto out;
+ {
+ g_prefix_error (error, "Loading metadata object %s: ", checksum);
+ goto out;
+ }
if (objtype == OSTREE_OBJECT_TYPE_COMMIT)
{
guint32 mode;
if (!ostree_repo_load_file (data->repo, checksum, &input, &file_info,
&xattrs, cancellable, error))
- goto out;
+ {
+ g_prefix_error (error, "Loading file object %s: ", checksum);
+ goto out;
+ }
mode = g_file_info_get_attribute_uint32 (file_info, "unix::mode");
if (!ostree_validate_structureof_file_mode (mode, error))